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(54) Controlling access to stored information 

(57) Access to stored information by a user is con- 
trolled by comparing an actual geographic position 
and/or an actual date/time with a geographic region 
and/or a date/time interval within which access to the 
stored information is authorized. The actual geographic 
position where the stored information is located, and the 
actual date/time can be determined, for example, based 
on signals received at a receiver supplying reliable posi- 
tion and time information, such as a GPS receiver. 
Access to the stored information is authorized if the 
actual geographic position and/or date/time falls within 
the authorized geographic region and/or date/time inter- 
val. The position and date/time information supplied by 
the receiver may be cryptographically signed and 
encrypted. 
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Description 

[0001] This invention relates to controlling access to stored information. 

[0002] Data distribution media, such as a CD-ROM, can store a large number of files. The producer of the CD-ROM 
5 may wish to control access by users to particular files, either because they are confidential or because access is subject 
to payment by the user. 

[0003] Access may be controlled by requiring a user to enter a password obtained from the CD-ROM producer. Dif- 
ferent passwords may unlock different files or different subsets of files. The files may be cryptograph icaliy signed and 
for added protection, may be encrypted. In the scheme discussed in U.S. Patent 5,646,992, incorporated herein by ret- 
ro erence, each file is encrypted by the producer with a unique Key known only to the producer. The user receives the 
encrypted items and, after his request for access is processed by the producer, also receives decryption keys, i.e., 
passwords, which are used to decrypt the respective encrypted files. The passwords unlock only those files for which 
access has been requested. 

[0004] In general, in one aspect of the invention, the invention features controlling access to stored information by 
15 determining an actual geographic position where the stored information is located based on signals received at a 
receiver supplying reliable position information. The actual geographic position is then compared with a geographic 
region within which access to the stored information is authorized. The user is permitted access to the stored informa- 
tion if the actual geographic position is located within the authorized geographic region. 

[0005] Embodiments of the invention include the following features. The receiver that supplies the position informa- 
nt? Won can receive the position information from a satellite-based location determination system or an inertial navigation 
system. The information can be stored on a computer- readable medium, such as a high -capacity disk. The stored infor- 
mation includes files and each of these files has an associated geographic region within which access is permitted. The 
user has access to a specific file or files if the actual geographic position is located within the authorized geographic 
region for this file. The stored information can be encrypted, and the user has access to the decryption key only if the 
25 actual geographic position is located within the authorized geographic region. The stored information can also be 
divided into subsets of information and wherein at least one the subsets has a different authorized region from the other 
subsets. The association of the files with the authorized geographic regions can be stored as a policy file together with 
the stored information. 

[0006] In general, in another aspect, the invention features determining an actual date or time at the location of the 
30 stored information based on signals received at a receiver supplying reliable time information. The actual date or time 
is compared with a predetermined date or time interval at which access to the stored information is authorized. The user 
can access the stored information if the actual date or time occurs within the authorized date or time interval. 
[0007] In general, in another aspect, the invention includes a receiver supplying reliable position information for 
determining an actual geographic position where the stored information is located. A computer receives the position 
35 information with a geographic region within which access to the stored information is authorized and permits access to 
the stored information if the actual geographic position is located within the authorized geographic region. Embodi- 
ments of the invention include the following features. The receiver includes a receiver encryption mechanism for cryp- 
tographically signing the actual geographic position with a receiver encryption key and verifying the receiver signature 
with a receiver decryption key before the actual geographic position is compared with the authorized geographic region. 
40 [0008] In general, in yet another aspect, the invention includes a reader with a corresponding receiver decryption 
key for verifying the cryptograph icaliy signed actual position. 

[0009] Embodiments of the invention include the following features. The reader generates an initialization vector 
providing a position offset which is transmitted to the receiver and added to the actual geographic position. The reader 
crytographically signs the position offset with a reader encryption key The receiver verifies the position offset signature 

45 with a corresponding reader decryption key before the position offset is added to the actual geographic position. 

[0010] In general, in another aspect, the invention features forming a policy associating the information with author- 
ized geographic regions and authorized time intervals and cryptographically signing the policy and the information. The 
signed policy is stored together with the signed information. The user obtains from the producer a password for unlock- 
ing the policy and obtains access to the stored information if the actual geographic position and actual time falls within 

so the authorized geographic regions and authorized time interval of the policy 

[001 1 ] Among the advantages of the invention are one or more of the following. 

[001 2] A producer of stored information can restrict use of that information to designated geographic regions or can 
exclude designated regions where use is not permitted. For example, a service manual for an automobile stored on a 
CD-ROM may contain differnt sections of information which are applicable to corresponding specific countries and/or 
55 regions. A user may be permitted to see only the portion of the information which is applicable to his current geographic 
location. Likewiese, access to a sensitive corpoarte report may be limited to specific plant location. Access to time-sen- 
sitive information may be denied before or after a certain date or limited to a permitted period. By associating informa- 
tion about authorized geographic regions and time intervals with policy files stored on the CD-ROM and accessed with 
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a user password, the CD-ROM producer can issue a new password to permit the user to access a particular set of pol- 
icy files, and therefore the information authorized, for a corresponding region and date/time. 
[0013] The invention will now be described by way of example and with reference to the accompanying drawings in 
which: 

5 

FIG. 1 is a perspective view of a computer system; 

FIG. 2 is a block diagram of a computer-based system for controlling access to stored information; 

FIGS. 3 through 5 are flow diagrams; 

FIG. 6 is a block diagram of cryptographic elements. 

10 

[0014] As seen in FIGS. 1 to 3, access to information which is stored on a portable computer-readable CD-ROM 
which serves as a data distribution media 35, may be controlled based on an actual geographic position of a computer 
system 10 on which the information is to be accessed and the time when it is to be accessed. 
[0015] In computer system 10, a computer 20 is connected to a keyboard 50, a mouse 60, a monitor 40, and a CD- 

15 ROM drive 30. A GPS receiver 70 serves as a source of reliable position and time information. The receiver 70 is 
located at the actual geographic position of the computer system 10 and receives signals 75 from orbiting GPS satel- 
lites 90 (only one shown). The receiver 70 converts the received signals 75 to geographic position data 71 to an accu- 
racy of several meters in longitude, latitude and height and to date/time data 71 to an accuracy of microseconds. The 
data 71 are transmitted to the computer 20 via a device driver 72. 

20 [001 6] A receiver crypto-board 80 may contain a public-key certificate 81 signed by the producer and a correspond- 
ing private key 82, as shown in FIG 6. The geographic position and date/time data 71 may then be signed with the pri- 
vate key 82 to authenticate the data. 

[0017] The CD-ROM drive 30 may also include encryption and signature capabilities (decoder 32) which may be 
implemented either in hardware or in software. The decoder 32 includes a crypto-board public-key certificate 83 which 
25 is identical to certificate 81 , a producer certificate 84 for verification of the producer's identity, and a distribution media 
policy decryption key 86 signed by the producer, as shown in FIG. 6. The crypto-board certificate 83 verifies the signa- 
ture of the crypto-board 80 signed with the private key 82. The policy decryption key 86 decrypts the access policy 155 
stored on the CD-ROM 35. 

[0018] The computer system 10 can have several levels of security, such as Level 1 and Level 2, described in the 
30 following examples. 

[0019] In a system with Level 1 security, the receiver 70 communicates with the computer 20 via a conventional 
device driver 72 and the CD-ROM drive 30 is a conventional CD-ROM. Neither the receiver 70 nor the CD-ROM drive 
30 have additional encryption/decryption capabilities. For increased security, the computer 20 in a Level 1 system can 
be a "trusted" computer which can authenticate and/or encrypt data. In a more secure, Level 2 system, the receiver 70 
35 may include a cryptoboard 80 and the CD-ROM drive 30 may include a decoder 32. The Level 2 system is designed to 
provide data authenication and encrypted data transmission between the receiver 70 and the decoder 32. The compu- 
ter 20 can then be any commerical computer without data authentication and encryption. 

[0020] Data entered via the keyboard 50 and mouse 60 may include typical command and data input 130 entered 
via a user interface 95 (provided by an application program 34) and one or more passwords 130 that permit a user to 

40 gain access to information stored on the data distribution media 35. 

[0021] The CD-ROM 35 stores different types of information, such as files with information 144, a list 150 of author- 
ized geographic regions, a list 154 of authorized date/time intervals, one or more file , decryption key files 146, one or 
more policy files 152 and a signature 147 for the entire CD-ROM 35. As seen in FIG. 3, the files 144, 146, 150, 152, 
154 and 155 may be signed and encrypted. 

45 [0022] The files 144 may be grouped in subsets 141 , 142 and 143. Files may belong to more than one subset. (In 
the following discussion, the term file refers to both files and subsets of files.) Each file 141, 142 and 143 may be 
encrypted with a unique file encryption key 51 (E 1( E 2 , E 3 ). The corresponding file decryption keys 52 (K 1( K 2 , K 3 ) are 
stored on the CD-ROM 35 in the file decryption key file 146. Additional information about the decryption keys and the 
decryption key file are found in U.S. Patent 5,646,992. 

so [0023] Each file 141, 142 and 143 on the CD-ROM 35 is associated with zero, one or more of the authorized geo- 
graphic regions stored in the list 150 of authorized geographic regions. For example, a region may be bordered by lati- 
tudes and longitudes corresponding to the extent of the Empire State Building in New York City and an altitude of 
between 50 and 60 meters, so that the file associated with that region can only be opened if the receiver 70 is located 
in a certain office area inside the Empire State Building. 

55 [0024] Likewise, each file 141 , 142 and 143 is associated with zero, one or more of the authorized date/time inter- 
vals stored in the list 154 of authorized date/time intervals. 

[0025] Each GPS satellite 90 maintains an extremely accurate clock. The receiver 70 receives the GPS clock sig- 
nals as part of signals 75, or a local atomic clock can provide similar clock signals. The clock signals enable control of 
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access to the information based on the actual time when access to the information is attempted. For example, the pro- 
ducer can specify that access, is to be granted only (1) before a predetermined date/time; (2) after a predetermined 
date/time; or (3) only during a predetermined date/time period. 

[0026] The producer can associate the files 141, 142 and 143 with specific items in the lists 150 and 154viaapass- 
s word 130 which the user enters via keyboard 50. The password 130 can be a user password valid for more than one 
access, or can be a one-time password. Alternately, the producer can associate specific geographic region/date/time 
information of lists 150 and 154 with the files 141, 142 and 143 via the policy files 152. A valid user password 130 may 
unlock one or more policy files 1 52. If the user's actual geographic position and the current date and time are within the 
authorized geographic region and the authorized date/time corresponding to the user password 150, then the user can 
io access the selected files via the user interface 95. The selected information is then displayed on output device 40. 
[0027] Table 1 shows, as an example, how five encrypted files, A to F, stored on the CD-ROM 35 and associated 
with corresponding authorized geographic regions and datesAimes, can be accessed. Each file is associated with one 
of four different file decryption keys K1 to K4. L1 and L2 are two different authorized geographic regions and T1 , T2 and 
T3 are three different authorized date/time intervals. The user who is in possession of the file decryption key K1 , e.g., 
15 a password, can decrypt Manual A within the geographic regions L1 and L3 at time T1 . The same user can also decrypt 
Manual D at the same time T1 in regions L2 and L3, but not within region L1 . Likewise, the user who has key K2 can 
decrypt Image B and Image E within the region L2, but not at the same time. Drawing C can be decrypted with key K3 
at any location, but only at time T3, while the Business Report F requires key K4 and can be decrypted at any time, but 
only within the region L1. 

20 
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[0028] As shown in FIG. 3, for purposes of cryptographic signature with optional encryption, the producer selects 
source files 144' to be written on the CD-ROM 35 and specifies a list of authorized geographic regions 150' and a list 
of authorized date and time intervals 154'. The producer associates (as shown in Table 1) each file or subset of files 
with zero, one or more geographic regions 150' and zero, one or more date/time intervals 154' and stores this associa- 
te tion in a policy file 152' Each of the files 144', 150', 152', 154' can be signed and encrypted in steps 53, 340, 350 and 
360 with corresponding encryption keys 51 , 345, 355 and 365, respectively The corresponding encrypted files 150, 152 
and 154 are then stored together on the CD-ROM 35 as a signed, encrypted regionAime/file access policy 155. Also 
stored on the CD-ROM 35 are, as mentioned above, the signed/encrypted files 1 44, the signed/encrypted symmetric 
file decryption key file 146 and the signature 147 used by the producer to sign the entire CD-ROM 35. 
45 [0029] As seen in FIGS. 4 and 5, to gain access to the signed/encrypted files 144, the user obtains a password 130 
(FIG. 2) from the producer (step 400), and enters the password 130 via the keyboard 50 (step 410). The password 130 
is assumed to be a one-time password, although user passwords valid for more than one session can also be used. 
[0030] As seen in FIG. 4, the early portions of the process flow for Level 1 and Level 2 are almost identical. 
[0031] Step 420 checks the password 130 and the process then executes either 440 (for Level 1, with no additional 
so security) or to 450 (for Level 2, with receiver/CD-ROM drive security), depending on the system configuration. Details 
of steps 440 and 450 are shown in FIG. 5 and will now be discussed. 

[0032] As seen in FIG. 5, in process 440 the user password 130 is sent to the device driver 72 (step 510). In 
response to the one-time password 1 30, the device driver 72 generates from the user's password 1 30 its own one-time 
password (step 520) and verifies (step 530) that the user did indeed enter a correct one-time password 130, thus 
55 authenticating the user for the interactive session (step 532). Otherwise, access is denied (step 535), 

[0033] Once the password 130 has authenticated the user, the device driver 72 interrogates the receiver 70 for the 
current position and date/time (step 540). The device driver 72 then compares the time and position data returned by 
the receiver 70 with the policy 155 which applies to the files 144 or a subset 141, 142 and 143 of files (step 460). If the 
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user is authorized to access the files 1 44, then the data is unlocked, decrypted (step 470, FIG. 3) with decryption keys 
52 (step 480) and supplied to the user's application program 34 (step 490) and displayed. 

[0034] In a Level 2 system, the receiver 70 includes the cryptographic receiver board 80, hereafter referred to as 
"crypto-board". As mentioned before, crypto-board 80 can sign and encrypt/decrypt messages. The CD-ROM drive 30 
5 includes decoder 32 to decode the position data signed by and received from the crypto-board 80. 

[0035] As seen in FIG. 5, in process 450, the user's password 1 30 is sent to the device driver 72, which accepts the 
password 130 and passes it through unaltered to the decoder 32 (step 550). The driver 32 then internally generates 
with the private key 86 its own onetime password corresponding to the user's password (step 560) and verifies (step 
570) that the correct password 1 30 was communicated by the device driver 72, thus authenticating the user for the inter- 
ne active session (step 572). Otherwise, access is denied (step 575). 

[0036] Once the encryption circuit 32 has authenticated the user, the driver 32 interrogates the crypto-board 80 via 
the device driver 72 for the current time and position information from receiver 70 (step 580). The decoder unit 30 pro- 
vides the crypto-board 80 with a signed random or other bit pattern to form an "initialization vector" (step 590), i.e., a 
position offset, which the device driver 72 passes through the crypto-board 80 along with the request for the time and 
is position (step 590). 

[0037] The crypto-board 80 responds by preparing a packet according to a pre-established data format which 
includes the current time and the actual geographic position in latitude and longitude and altitude (step 600). Also 
included may be information identifying the satellites transmitting the position data as well as other data necessary for 
the computations. The crypto-board 80 also stores the provided initialization vector at a known offset within the packet 

20 and applies a cryptographic signature to the contents of the packet. The cryptographic signature can be, for example, 
a message digest/hash of the packet data, plus an encryption of the message digest according to some predetermined 
key, and may be symmetrical or asymmetrical, depending on the key or certificate stored on the crypto-board 80. 
[0038] The crypto-board 80 then transmits (step 605) the signed time/location packet to the device driver 72 which 
relays the packet to the decoder 32/CD-ROM drive 30. The decoder 32 compares the signature of the packet received 

25 from the crypto-board 80 with a signature stored in the decoder 32 (step 610), If the signature verifies properly (step 
620), the initialization vector within the packet is examined to determine if the initialization vector is indeed the same 
initialization vector which the decoder 32 provided to the crypto-board 80 in step 590. If this is the case, then the packet 
received by the decoder 32 is recent and genuine, and the time and position data are accepted as valid. 
[0039] Once the packet from the crypto-board 80 is authorized based on the signature and the initialization vector, 

30 the decoder 32 compares the time and position data received from the crypto-board 80 with the policy 155 which 
applies to the files 144 or to a subset of files 144 (step 460). If the user is authorized to access the files 144, then the 
data is unlocked (step 470), decrypted with decryption keys 52 (step 480) and supplied to the user's application pro- 
gram 34 and displayed (step 490). 

[0040] Variations to the above specifically described embodiments are possible. For example, the GPS receiver 
35 need not be located at the exact position of the data distribution media reader but could be in a known location (such 
as a room containing a control server providing computer service to a local area network in a building) relative to the 
reader. 

[0041 ] The policy files 1 52' may also designate geographic regions where access to certain files 1 44 is denied. 
[0042] Control over access to files need not be limited to the use of passwords provided by the producer and 
40 entered via a keyboard. For example, certain biometric attributes, such as facial features, finger prints and/or voice 
prints may be substituted for or used in addition to passwords. 

Claims 

45 1. A method for controlling access to stored information comprising determining an actual geographic position where 
said stored information is located based on signals received at a receiver supplying reliable position information, 
comparing said actual geographic position with at least one authorized geographic region, and permitting access 
to said stored, information if said actual geographic position is within said authorized geographic region. 

50 2. The method of Claim 1, wherein said stored information comprises files and each of said files has an associated 
geographic region within which access is permitted, and further permitting access to said file if said actual geo- 
graphic position is located within said authorized geographic region for said file. 

3. The method of Claim 2, further comprising denying access to said stored information if said actual geographic posi- 
55 tion does not match said authorized geographic region. 

4. The method of Claim 2 or 3, wherein said association of the files with the authorized geographic regions is stored 
as a policy file together with said stored information. 
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5. The method of any preceding claim, further comprising encrypting said stored information using an encryption key, 
and providing a decryption key which permits decryption of said stored information, if said actual geographic posi- 
tion is located within said authorized geographic region. 

5 6. The method of any preceding claim further comprising cryptographically signing said actual geographic position 
with a receiver encryption key, and verifying the receiver signature with a receiver decryption key before the actual 
geographic position is compared with said authorized geographic region. 

7. The method of any preceding claim, wherein said stored information is divided into subsets of information and 
10 wherein at least one of the subsets has a different authorized region from the other subsets, so that access is 

authorized to the subset whose authorized geographic region is located within the actual geographic position, but 
not to the subsets whose authorized geographic region is not located within the actual geographic position. 

8. A method for controlling access to a subset of files belonging to a larger set of files of stored information comprising 
w associating a unique file encryption key with each file from the larger set of files and encrypting the files using the 

associated encryption keys, associating each of the files from the larger set of files with at least one authorized geo- 
graphic region within which access to said stored information is authorized, determining an actual geographic posi- 
tion where said stored information is located based on signals received at a receiver supplying reliable position 
information, comparing said actual geographic position with said authorized geographic region, and providing a file 
20 decryption key which authorizes access to and permits decryption of said files belonging to said subset of files, pro- 
vided that the actual geographic position is located within the authorized geographic region for the files belonging 
to said subset of files. 

9. The method of Claim 8, wherein said association of the files with the authorized geographic regions is stored as a 
25 policy comprising policy files wherein each policy file is accessible with a user password and authorizes, if the user 

password is valid, access to the files listed in said policy file, if the actual geographic position which is located within 
the authorized geographic region associated with the files. 

10. The method of Claim 9, wherein said policy is stored with the stored information. 

30 

1 1 . A method for controlling access to stored information comprising determining an actual date or time at the location 
of said stored information based on signals received at a receiver supplying reliable time information, comparing 
said actual date or time with a predetermined date or time interval at which access to said stored information is 
authorized, and permitting access to said stored information if said actual date or time occurs within said authorized 

35 date or time interval. 

12. The method of Claim 11, further comprising denying access to said stored information if said actual date or time 
does not occur within said authorized date or time interval. 

40 13. The method of Claim 11 or 12, wherein said information comprises files and each of said files has an associated 
authorized date or time interval within which access is permitted, and further permitting access to said file if said 
actual date or time occurs within said associated authorized date or time interval. 

14. The method of any one of Claims 1 1 to 13, wherein said stored information is divided into subsets of information 
45 and wherein at least one of the subsets has a different authorized date or time interval from the other subsets, so 

that access is authorized to the subset whose authorized date or time interval matches the actual date or time, but 
not to the subsets whose authorized date or time interval does not match the actual date or time. 

15. A method for controlling access to stored information comprising forming a policy associating said information with 
so authorized geographic regions and authorized time intervals, cryptographically signing said policy and said infor- 
mation, storing said signed policy together with said signed information, providing a password for unlocking said 
policy, and determining an actual geographic position where said stored information is located based on signals 
received at a receiver supplying reliable position information, determining an actual time, comparing said actual 
geographic position and said actual time with said authorized geographic regions and authorized time interval of 

55 said policy, and permitting access to said stored information if said actual geographic position and actual time falls 
within said authorized geographic regions and authorized time interval of said policy. 

16. A method as claimed in any one of Claims 1 to 10, wherein the method further includes determining an actual time, 
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comparing said actual time with an authorized time interval and permitting access to said stored information if said 
actual time fails within said authorized time interval. 

17. The method of Claim 15 or 16, wherein said source of reliable position and time is a Global Orbiting Navigational 
s Satellite System. 

18. The method of Claim 15 or 16, wherein said source of reliable position and time is a inertial navigation system. 

19. The method of Claim 15 or 16, wherein said source of reliable position and time is a satellite based location deter- 
10 mination system. 

20. The method of any preceding claim, wherein said receiver comprises a GPS receiver. 

21. The method of any preceding claim, wherein said information is stored on a computer-readable medium. 

15 

22. The method of Claim 21 , wherein said computer-readable medium is portable. 

23. The method of Claim 21 , wherein said computer-readable medium comprises a high-capacity disk. 

20 24. Apparatus for controlling access to stored information comprising a receiver supplying reliable position information 
for determining an actual geographic position where said stored information is located, and a computer for compar- 
ing said actual geographic position with a geographic region within which access to said stored information is 
authorized, wherein said computer permits access to said stored information if said actual geographic position is 
located within said authorized geographic region. 

25 

25. The apparatus of Claim 24, wherein said receiver is a GPS receiver. 

26. The apparatus of Claim 24 or 25, the receiver further comprising a receiver encryption mechanism providing a 
receiver encryption key for cryptographically signing the actual geographic position. 

30 

27. The apparatus of Claim 26, further comprising a reader for reading said stored information wherein said reader 
comprises a receiver decryption key for verifying said cryptographically signed actual position. 

28. The apparatus of Claim 25, wherein said reader generates an initialization vector providing a position offset which 
35 is transmitted to the receiver and added to the actual geographic position. 

29. The apparatus of Claim 28, further comprising a reader encryption mechanism providing a reader encryption key 
for cryptographically signing the position offset, wherein said position offset signature is verified by the receiver with 
a corresponding reader decryption key before the position offset is added to the actual geographic position. 

40 
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